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Prufungsantrag gem. § 44 PatG ist gestellt 

® 10- und Speicherbussystem fur DFPs sowie Bausteinen mit zwei- oder mehrdimensionaler programmierbaren 
Zellstrukturen 

® Es wird ein Bussystem vorgeschlagen, das durch Bun- 
delung mehrerer einzelner Leitungen oder Busse oder 
Teilbusse innerhalb eines Bausteines der Gattung DFP, 
FPGA, DPGA, sowie alien Bausteinen mit zwei- oder 
mehrdimensionaler programmierbarer Zellstruktur her- 
gestellt ist, und uber welches die Bausteine zu mehreren 
zusammengefafctwerden konnen und/oderSpeicher und/ 
oder Peripherie anschlieGbar sind/ist 
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Beschreibung 

1 Hintergrund der Erfindung 

5 1.1 Stand der Technik 

1.1.1 ... in DFP-basierenden Systemen 

In DFPs gemaB DE 44 16 881 Al werden die Leitungen jeder Kantenzeile, das ist eine Zelle, die sich am Rand eines 
10 Zellarrays befindet und oftmals direkten Kontakt nut den Anschlussen des Bausteines haben kann, uber die Anschlusse 
des Bausteines herausgefiihrt Dabei haben die Leitungen keine spezielle Funktion, vielmehr ubernehmen sie die Funk- 
tion, die in den Kantenzellen beschrieben ist. Werden mehrere DFPs miteinander vernetzt, so werden alle Anschlusse zu 
einer Matrix miteinander verbunden. 

15 1.1.2 ... in Systemen mit zwei- oder mehrdimensionalen programmierbaren Zellstrukturen (FPGAs, DPGAs) 

In Systemen mit zwei- oder mehrdimensionalen programmierbaren Zellstrukturen (FPGAs, DPGAs) wird eine be- 
stimmte Teilmenge von internen Bussystemen und Leitungen der Kantenzellen iiber die Anschlusse des Bausteines her- 
ausgefiihrt. Dabei haben die Leitungen keine spezielle Funktion, vielmehr ubernehmen sie die Funktion, die in den Kan- 
20 tenzellen beschrieben ist. Werden mehrere FPGAs/DPGAs miteinander vernetzt, so ubernehmen die Anschlusse die 
Funktion, die hardware- oder softwareseitig implemenuert wurde. 

1.2Probleme 

25 1 .2.1 ... in DFP-basierenden Systemen 

Der Verdrahtungsaufwand fur die Peripherie oder Vemetzung von DFPs ist sehr hoch. Da gleichzeitig der Prograrn- 
mierer dafur zu sorgen hat, daB die entsprechenden Funktionen in die Zellen des/der DFPs integriert werden. Zum An- 
schluB eines Speichers muB eine Speicherverwaltung in den Baustein integriert werden. Zum AnschluB von Peripherie 
30 muB diese unterstutzt werden, ebenso wie die Kaskadierung von DFPs entsprechend berucksichtigt werden muB. Der 
Aufwand ist verhaltnismaBig hoch, gleichzeitig gehtFlache auf dem Baustein fur die jeweiligen Implementierungen ver- 
loren. 

1.2.2 ... in Systemen mit zwei- oder mehrdimensionalen programmierbaren Zellstrukturen (FPGAs, DPGAs) 

35 

Oben beschriebenes gilt ebenfalls fur FPGAs und DPGAs, ins besondere, wenn diese zur Implementierung von Algo- 
rithmen eingesetzt werden und als numerische (Co)Prozessoren arbeiten. 

1.3 Verbesserung durch die Erfindung, Aufgabe 

40 

Der Verdrahtungsaufwand, ins besondere die Anzahl der Bausteinanschliisse wird erheblich reduziert. Ein einheitli- 
ches Bussystem arbeitet ohne besondere Rucksichtnahme durch den Programmierer. Die Steuerung des Bussyslems ist 
fest implementiert. Ohne besondere MaBnahmen kann an das Bussystem Speicher, sowie Peripherie angeschlossen wer- 
den. Ebenfalls konnen Bausteine mit Hilfe das Bussystems kaskadiert werden. 

45 

2 Beschreibung der Erfindung 

2.1 Ubersicht uber die Erfindung, Abstrakt 

50 Die Erfindung beschreibt ein allgemeines Bussystem, das eine Vielzahl bausteininterner Leitungen zusammenfaBt und 
als Bundel an die Anschlusse herausfuhrt. Die Steuerung des Bussystems ist dabei vordefiniert und bedarf keines Ein- 
flusses durch den Prograrnrnierer. An das Bussystem lassen sich beliebig Speicher, Peripherie oder weitere Bausteine 
(zur Kaskadierung anschlieBen). Die Einzelheiten und besondere Ausgestaltungen, sowie Merkmale des erfindungsge- 
maBen Bussystems sind Gegenstand der Patentanspriiche. 

55 

2.2 Detailbeschreibung der Erfindung 

Die nachfolgende Beschreibung umfafit mehrere Strukturen, die wie bei DFPs, FPGAs, DPGAs, o. 1 ublich von einer 
Ladelogik aus gesteuert und konfiguriert werden. Dabei konnen Tfeile der Ladelogik auf dem Baustein integriert sein. Al- 
60 ternativ besteht die Moglichkeit (Fig. 6/7) die Strukturen durch den Baustein selbst direkt dynamisch umzukonfigurieren 
oder zu steuern. Dabei konnen die Strukturen fest auf dem Baustein implementiert sein, oder erst durch Konfiguration 
und moglicherweise ZusammenschluB mehrere Logikzellen, das sind konfigurierbare Zellen, die einfache logische oder 
arithmetische Aufgaben gemaB ihrer Konfiguration erfullen (vgl. DFP, FPGA, DPGA), entstehen. 

65 2.2. 1 Bundelung intemer Leitungen 

Um sinnvolle Busstrukturen zu erhalten, wird eine Mehrzahl interner Leitungen wird zu Bussen (I-BUSn; n gibt die 
Nummer des Busses an) zusarnmengefafit. Dabei kann es sich bei den Leitungen um interne Bussysteme oder um Lei- 
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tungen der KantenzeUen handeln. Die einzelnen Busse werden fur Schreibzugriffe auf den externen Bus (E-BUS) iiber 
taktsynchrone Latche oder Register (I-GATE-REG) auf Tore gefuhrt, die als Schalter zum E-BUS arbeiten. Eine derar- 
tige Einheit wird Ausgabezelle (OUTPUT-CELL) genannt. Der Zugriff auf den E-BUS geschieht derart, dafi die einzel- 
nen Latche iiber die Tore auf den gemeinsamen E-BUS geschaltet werden. Dabei ist immer nur ein Tor geoffnet. Jeder I- 
BUSn besitzt eine eindeutige Kennummer (n: z. B. I-BUS1, 1-BUS976, . . .). 

Fur Lesezugriffe wird der hereinfuhrende E-BUS in taktsynchrone Latche oder Register (E-GATE-REG) zwischenge- 
speichert und dann iiber die Tore an die I-BUSn verteilt. Eine derartige Einheit wird Eingabezelle (INPUT-CELL) ge- 
nannt. Der AbgrifF vom E-BUS geschieht dabei derart, dafi ein E-BUS-Transfer in ein oder mehrere E-GATE-REG ge- 
schrieben wird. Die E-GATE-REG konnen dann entweder einzeln oder gemeinsam auf ihre intemen Bussysteme freige- 
schaltet werden. 

Dabei konnen die Schreib-ZLesezugriffe in beliebiger Reihenfolge ablaufen. Es ist unter Umstanden sinnvoll die inter- 
nen Busse I-BUSn in zwei Gruppen zu unterteilen, die schreibenden Ausgabebusse IO-BUSn und die lesenden Eingabe- 
bussen-BUSn. 
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2.2.2 AdreBgenerierung 15 

Fur die meisten ZugrifTe auf externe Bausteine ist es notwendig Adressen zur Auswahl eines Bausteines oder Teilen 
eines Bausteines zu generieren. Dabei konnen die Adressen fest sein, das heifit sie andern sich nicht (dies ist vor allem bei 
Peripherieadressen der Fail) oder die Adressen verandern sich bei jedem Zugriff um (meist) feste Werte (dies ist vor al- 
lem bei Speicheradressen der Fall). Zur Generierung der Adressen existieren programmierbare Zahler fur die Lesezu- 20 
griffe und programmierbare Zahler fur die Schreibzugriffe. Die Zahler werden durch die Ladelogik, das ist die Einheit, 
die die, auf einer Zellstruktur basierenden konfigurierbaren Bausteine (DFPs, FPGAs, DPGAs o. a.) konfiguriert, auf ei- 
nen Grundwert eingestellt. Bei jedem Zugriff auf das Tor zahlt der Zahler je nach Einstellung um einen von der Ladelo- 
gik festgelegten Wert nach oben oder unten. Ebenfalls kann jeder Zahler als Register verwendet werden, das bedeutet, bei 
einem Zugriff wird nicht gezahlt, der im Zahler eingestellte Wert ist statisch. Jedem Bustransfer wird als Adresse der 25 
Wert des zum Tor gehorenden Zahlers zugeordnet. Die Einstellung des Zahlers geschieht iiber ein Einstellungsregister 
(MODE-PLUREG), das von der Ladelogik beschrieben wird. 



2.2.3 Masken und Zustande 

Jedem Tor ist eine Anzahl Bits im spater beschriebenen MODE-PLUREG zugeordnet, die angibt, ob der Tor akuv ist 
oder von der Steuerung iibergangen wird, also ausmaskiert ist (MASKE). Das bedeutet, der Tor wird beim Durchlaufen 
aller Tor zum Aufschalten auf das jeweilige Bussystem iibergangen. 

Folgende Masken-Eintrage sind denkbar: 

- INPUT-/OUTPUT-CELL immer ubergehen 

- INPUT-/OUTPUT-CELL nur beim Schreiben ubergehen 

- INPUT-/OUTPUT-CELL nur beim Lesen ubergehen, wenn der EBUS-MAS- TER nicht auf die INPUT-/OUT- 
PUT-CELL zugegriffen hat 

- INPUT-/OUTPUT-CELL niemals ubergehen 

Jedem Tor ist ein Zustandsregister, das als RS-Flipflop ausgestallet sein kann, zugeordnet. Dieses Register zeigt an, ob 
Daten in das zum Tor gehorenden Register geschrieben wurden. 
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2.2.4 Das MODE-PLUREG 
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Das MODE-PLUREG kann von der Ladelogik beschrieben und gelesen werden. Es dient zur Einstellung des Bussy- 
stems. 

Ein moglicher Aufbau des MODE-PLUREG aus Sicht der Ladelogik 



Bit l..m 


Bit k..l 


Bit 2..k 
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Bit 0 
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vordeflnierter 
Wert 
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0=additiv zahlen 
l=subtraktiv zahlen 


0=Register 
l=Zahler 


maskier&i • 


Einstellungen fur Adressgenerator 
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2.2.5 Beschreibung der INPUT-CELL 

Es wird unterschieden, ob Daten vom E-BUS in den Baustein gelangen (die dafur notwendige Einheit wird INPUT- 60 
CELL genannt) oder ob Daten aus dem Baustein auf den E-BUS gelangen (die dafur notwendige Einheit wird OUTPUT- 
CELL genannt). 

Eine INPUT-CELL kann wie folgt ausgestaltet sein: Ein Latch (I-GATE-REG), das entweder vom externen E-BUS- 
MASTER oder der bausteineigenen Zustandsmaschine gesteuert wird, dient zur Zwischenspeicherung der Daten, die 
vom E-BUS erhalten werden. Dabei ist das Taktsignal des Latches an ein (z. B.) RS-Flipflop (SET-REG) gefuhrt, das den 65 
Zugriff auf das I-GATE-REG festhalt. Hinter dem I-GATE-REG befindet sich ein Tor (I-GATE), das von der Zustands- 
maschine gesteuert wird. Uber das I-GATE gelangen die Daten aus dem I-GATE-REG auf den I(I)-BUSn. 

Des weiteren befindet sich ein programmierbarer auf/abwarts-Zahler in der INPUT-CELL. Er kann nach jedem akti- 
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ven Lesezugriff auf den E-BUS durch die Zustandsmaschine gesteuert, urn einen einstellbaren Wert hoch- oder herunter- 
zahlen. Ebenfalls kann er als einfaches Register dienen. Dieser Zahler generiert die Adressen fur Buszugriffe, in denen 
der Baustein E-BUS-MASTER ist. Die Adressen werden durch ein Tor (ADR-GATE) auf den E-BUS gefuhrt. Das ADR- 
REG wird von der Zustandsmaschine gesteuert. 
5 t)ber ein weiteres Tor (STATE-GATE) kann der E-BUS -MASTER den Zustand des SET-REG abfragen. Jede INPUT- 
CELL besitzt ein MODE-PLUREG, in dem die Ladelogik den Zahler konfiguriert und die INPUT-CELL aus- oder ein- 
schaltet (maskiert). 

2.2.6 Beschreibung der OUTPUT-CELL 

10 

Eine OUTPUT-CELL kann wie folgt ausgestaltet sein: Ein Latch (E-GATE-REG), das von der bausteineigenen Zu- 
standsmaschine gesteuert wird, dient zur Zwischenspeicherung der Daten, die vom I-BUS erhalten werden. 

Des weiteren befindet sich ein programmierbarer au^abwarts-Zahler in der OUTPUT-CELL. Dabei ist das Taktsignal 
des Latches an ein (z. B.) RS-Flipflop (SET-REG) gefuhrt, das den Zugriffauf das E-GATE-REG festhalt. Er kann nach 
15 jedem aktiven Lesezugriff auf den E-BUS durch die Zustandsmaschine gesteuert, um einen einstellbaren Wert hoch- 
oder herunterzahlen. Ebenfalls kann er als einfaches Register dienen. Dieser Zahler generiert die Adressen fur Buszu- 
grifFe, in denen der Baustein E-BUS-MASTER ist. 

Die Daten des E-GATE-REG, die Adressen und der Zustand des SET-REG werden uber ein Tor (E-GATE), das ent- 
weder vom externen E-BUS-MASTER oder der bausteineigenen Zustandsmaschine gesteuert wird, auf den gefuhrt. Jede 
20 OUTPUT-CELL besitzt ein MODE-PLUREG, in dem die Ladelogik den Zahler konfiguriert und die OUTPUT-CELL 
aus- oder einschaltet (maskiert). 

2.2.7 Steuerung des Bussystems 

25 Den einzelnen Toren, AdreBgeneratoren und Masken ist eine Steuerung ubergeordnet. Diese besteht aus einer einfa- 
chen Zustandsmaschine nach dem Stand der Technik. Dabei werden zwei Betriebsarten unterscheiden: 

1. Eine Aktive, in der die Zustandsmaschine den internen Bus (I-BUS) und den externen Bus (E-BUS) steuert. 
Diese Betriebsart wird E-BUS-MASTER genannt, da die Zustandsmaschine die Kontrolle uber den E-BUS besitzt. 
30 2. Eine Passive, in der die Zustandsmaschine nur den internen Bus (I-BUS) steuert. Der E-BUS wird von einem an- 

deren externen Baustein kontrolliert. Die Zustandsmaschine reagiert in dieser Betriebsart auf die Anforderungen 
des externen E-BUS-MASTERS . Diese Betriebsart wird E-BUS-SLAVE genannt. 

Die Steuerung verwaltet das E-BUS Protokoll. Dabei ist der Ablauf unterschiedlich, je nachdem, ob die Steuerung als 
35 E-BUS-MASTER oder E-BUS-SLAVE arbeitet. Ein Busprotokoll wird in dieser Schrift nicht beschrieben, da eine Viel- 
zahl von Protokollen nach dem Stand der Technik implementiert werden konnen. 

2.2.8 E-BUS-MASTER und E-BUS-SLAVE, das EB-REG 

40 Zur Verwaltung des Datenverkehrs auf dem E-BUS existiert das E-BUS-Steuerregister (EB-REG). Es ist in Reihe mit 
den Toren geschaltet und kann vom E-BUS aus adressiert und angesprochen werden. Uber folgende Eintrage konnte der 
Datenaustausch geregelt werden: 

I-WRTTE: zeigt an, daB der I-BUS komplett in die INPUT-/OUTPUT-CELLs geschrieben ist 
I-READ: zeigt an, daB der I-BUS die INPUT-/OUTPUT-CELLs komplett gelesen hat 
45 E-WRJTE: zeigt an, daB der E-BUS komplett in die INPUT-/OUTPUT-CELLs geschrieben ist 
E-READ: zeigt an, daB der E-BUS die lNPUT-/OUTPUT-CELLs komplett gelesen hat 

Das EB-REG ist immer nur auf der Seite des E-BUS-SLAVE aktiv und der E-BUS-MASTER greift lesend und schrei- 
bend darauf zu. 

50 - Alle I-. . .-Eintrage werden vom E-BUS-SLAVE geschrieben und vom E-BUS-MASTER gelesen. 

- Alle E-. . .-Eintrage werden vom E-BUS-MASTER geschrieben und vom E-BUS-SLAVE gelesen. 

Ein E-BUS-SLAVE kann die Kontrolle uber den E-BUS fordem, in dem er das Bit REQ-MASTER in seinem EB- 
REG setzt. Erkennt der E-BUS-MASTER das Bit REQ-MASTER, so muB er seine Buskontrolle so bald wie moglich ab- 

55 geben. Dies geschieht, in dem er das Bit MASTER im EB-REG eines E-BUS-SLAVE setzt Er schaltet daraufhin sofort 
die E-BUS passiv. Der alte E-BUS-SLAVE wird zum neuen E-BUS-MASTER und der alte E-BUS-MASTER wird zum 
neuen E-BUS-SLAVE. Der neue E-BUS-MASTER ubernimmt die Steuerung des E-BUS. Zur Erkennung des erstens E- 
BUS-MASTERs nach einer Rucksetzung (RESET) des Systems, existiert ein AnschluB an jedem Baustein, der durch die 
voreingestellte Polaritat angibt, ob der Baustein nach einem RESET E-BUS-MASTER oder E-BUS-SLAVE ist Der Ein- 

60 trag MASTER im EB-REG kann auch von der Ladelogik gesetzt und zuruckgesetzt werden . Dabei hat die Ladelogik dar- 
auf zu achten, daB keinerlei Buskollisionen am EB-BUS entstehen oder laufende Transfers abgebrochen werden. 

2.2.9 E-BUS-MASTER schreibt Daten in E-BUS-SLAVE 

65 FoigendermaBen kann der E-BUS-MASTER Daten in den ErBUS-SLAVE schreiben: 

»— Die Datenubertragung beginnt damit, daB die Zustandsmaschine des E-BUS-MASTERs eine OUTPUT-CELL 
auswahlt, die nicht ausmaskiert ist. 
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Im I-GATE-REG sind, je nach Ausfiihrung der Zustandsmaschine, bereits Daten gespeichert oder die Daten wer- 
den jetzt gespeichert. 
i — ► Das Tor wird aktiviert. 

Die giiltige Leseadresse wird auf den Bus ubertragen. 
~> Die Daten gelangen auf den E-BUS und werden in das E-GATE-REG des E-BUS-SLAVE gespeichert. 
Dadurch wird das SET-REG im E-BUS-SLAVE aktiviert. 
Das Tor im E-BUS-MASTER wird deaktiviert. 
Der AdreBzahler generiert die Adresse fur den nachsten Zugriff. 
Der Transfer ist fur den E-BUS-MASTER beendet. 

Auf der Seite des E-BUS-SLAVE existieren zwei Ausgestaltungsmoglichkeiten die Daten vom Bus in den Baustein zu 
transferieren: 

1. Das Daten-Tor ist immer offen und die Daten gelangen direkt vom E-GATE-REG auf den I-BUSn. 

2. Die Zustandsmaschine erkennt, da8 SET-REG aktiviert ist und aktiviert das Tor, dadurch kann SET-REG zu- 
riickgesetzt werden. 

Der E-BUS-MASTER kann dem E-BUS-SLAVE mitteilen, wann ein kompletter Buszyklus beendet ist. (Ein Buszy- 
klus ist als das Ubertragen mehrerer Datenworte an unterschiedliche E-GATE-REG definiert, wobei jedes E-GATE-REG 
genau ein Mai angesprochen werden darf.) 

Dazu setzt der E-BUS-MASTER am Ende eines Buszyklus das Bit E- WRITE im EB-REG des E-BUS-SLAVE. 

Der E-BUS-SLAVE kann darauf reagieren, in dem er die IOTUT-CELLs abfragt. 
t— Hat er alle INPUT-CELLs abgearbeitet, setzt er das Bit I-READ in seinem EB-REG. 
h+ Dabei setzt er WRITE und samtliche SET-REG der INPUT-CELLs zuriick. 

Der E-BUS-MASTER kann I-READ abfragen und nach dessen Aktivierung einen neuen Buszyklus beginnen. 
\-f I-READ wird durch Schreiben von E- WRITE oder den ersten Bustransfer zuruckgesetzt. 

Der E-BUS-SLAVE kann anhand des Zustandes des EB-REG oder der einzelnen SET-REG der INPUT-CELLs aus- 
werten, ob die INPUT-CELLs neu gelesen werden konnen/mussen. 

2.2.10 E-BUS-MASTER liest Daten von E-BUS-SLAVE 

Aus der Sicht des E-BUS-MASTERs existieren zwei grundlegende Methoden Daten vom E-BUS-SLAVE zu lesen: 

1. Verfahren, in dem die E-BUS-Daten direkt auf den I-BUS gelangen: 

Die Datenubertragung beginnt damit, daB die Zustandsmaschine des E-BUS-MASTERs eine INPUT-CELL 
auswahlt, die nicht ausmaskiert ist. 
h-> Das I-GATE und das ADR-GATE werden aktiviert. 

~* Die giiltige Leseadresse wird auf den Bus ubertragen. 
j— ► Das I-GATE-REG ist transparent, d. h. es lafit die Daten auf den I-BUSn durch. 
i-> Das Tor im E-BUS-MASTER wird deaktiviert. 
»-* Der AdreBzahler generiert die Adresse fUr den nachsten Zugriff. 
i — ► Der Transfer ist fur den E-BUS-MASTER beendet. 

2. Verfahren, in dem die E-BUS-Daten im I-GATE-REG zwischengespeichert werden: 

Die Datenubertragung beginnt damit, daB die Zustandsmaschine des E-BUS-MASTERs eine INPUT-CELL 
auswahlt, die nicht ausmaskiert ist. 

Das I-GATE und das ADR-GATE werden aktiviert. 

^ Die giiltige Leseadresse wird auf den Bus ubertragen. 
* — ► Das I-GATE-REG speichert die Daten. 

Das Tor im E-BUS-MASTER wird deaktiviert 

Der AdreBzahler generiert die Adresse fur den nachsten ZugrifT. 
h> Der E^BUS-Transfer ist ftir den E-BUS-MASTER beendet. 

Alle am E-BUS-Transfer beteiligten INPUT-CELLs, dies kann anhand der Masken in den MODE-PLU- 
REG oder dem Zustand der SET-REG festgestellt werden, werden durchlaufen und die Daten auf den jeweili- 
gen I-BUS ubertragen. 

Fur den E-BUS-SLAVE sieht der Zugriff wie folgt aus: 

Durch den E-BUS wird das Tor aktiviert. 

Die Daten und der Zustand des mdglicherweise vorhandenen SET-REG gelangen auf den E-BUS. 
Das Tor wird deaktiviert. 

Der E-BUS-MASTER kann dem E-BUS-SLAVE mitteilen, wann ein kompletter Buszyklus beendet ist. 

i-+ Dazu setzt der E-BUS-MASTER am Ende eines Buszyklus das Bit E-READ im EB-REG des E-BUS-SLAVE. 
»-* Der E-BUS-SLAVE kann darauf reagieren, in dem er die OUTPUT-CELLs neu beschreibt. 
Hat er alle OUTPUT-CELLs abgearbeitet, setzt er das Bit I- WRITE in seinem EB-REG. 
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Dabei setzt er E-READ und samtliche SET-REG der OUTPUT-CELLs zuriick. 

Der E-BUS-MASTER kann I-WRITE abfragen und nach dessen Aktivierung einen neuen Buszyklus beginnen. 
I-WRTTE wird durch Schreiben von E-READ oder den ersten Bustransfer zuruckgesetzt. 

5 Der E-BUS-SLAVE kann anhand des Zustandes des EB-REG oder der einzelnen SET-REG der OUTPUT-CELLs aus- 
werten, ob die OUTPUT-CELLs neu beschrieben werden konnen/miissen. 

2.2.11 AnschluB von Speicher, Peripherie und Kaskadierung 

10 AuBer der Kaskadierung von gleichen Bausteinen (DFPs, FPGAs, DPGAs) kann an das beschriebene Bussy stern Spei- 
cher und Peripherie als untergeordnete SLAVE-Baustein (SLAVE) angeschlossen werden. Dabei kann Speicher und Pe- 
ripherie, sowie weitere Bausteine (DFPs, FPGAs) gemischt werden. Jeder angeschlossene SLAVE wertet die Adressen 
auf dem Bus aus und erkennt selbstandig ob er angesprochen ist. In diesen Betriebsarten ist der Baustein, der den Spei- 
cher oder die Peripherie, also die SLAVE-Bausteine anspricht, der Bus-MASTER (MASTER), d. h. der Baustein steuert 

15 den Bus und den Datentransfer. Die Ausnahme bilden intelligente Peripheriebausteine, wie z. B. SCSI-Konlroller, die 
selbstandig Transfers initieren und durchfuhren konnen und daher E-BUS-MASTER sind. 

2.2. 12 Zusammenfassung 

20 Durch das beschriebene Verfahren, lassen sich Bussysteme einfach und leistungsfahig an DFPs und FPGAs anschlie- 
Ben. Dabei konnen iiber die Bussysteme sowohl Speicher und Peripherie, als auch weitere Bausteine o.g. Gattung ver- 
bunden werden. 

Das Bussystem muB nicht ausschlieBlich in den DFPs, FPGAs und DPGAs implemetiert sein. Selbstverstandlich ist 
ein Mischbetrieb dieses Bussystemes mit den herkommlichen AnschluBstrukturen der Bausteine moglich. Damit konnen 
25 die Vorteile der jeweiligen Technik optimal genutzt werden. 

Es sind weitere Abiaufverfahren fUr das beschriebene Bussystem denkbar. Diese werden jedoch nicht beschrieben, da 
es sich um freie Ausgestaltungsmoglichkeiten handelt, die vom hier aufeuzeigenden Grundprinzip unabhangig sind. 

3 Kurzbeschreibung der Diagramme 

30 

Fig. 1 Zeichnung eines Basisbausteines als FPGA Typ A, 

Fig. 2 Zeichnung eines Basisbausteines als FPGA T^p B, 

Fig. 3 Zeichnung eines Basisbausteines als DFP, 

Fig. 4 Leitungsbiindelung in FPGAs, 
35 Fig. 5 Leitungsbiindelung in DFPs, 

Fig. 6 Eine OUTPUT-CELL, 

Fig. 7 Eine INPUT-CELL, 

Fig. 8 Die AdreBgenerierung, 

Fig. 9 Komplettes Bussystem mit Steuerung, 
40 Fig. 10 AnschluB von Speicher und Peripherie, 

Fig. 11 Das EB-REG, 

Fig. 12 Ausfuhrungsbeispiel. 

4 Detailbeschreibung der Diagramme 

45 

Fig. 1 zeigt einen FPGA nach dem Stand der Technik. 0101 stellt die internen Bussysteme dar, 0102 beinhaltet eine 
oder mehrere FPGA-Zelle(n). 0103 sind Teilbusse, die eine Teilmenge von 0101 darstellen und iiber Schalter (Crossbars) 
mit 0101 verbunden sind. 0103 kann auch interne Daten von 0102 verwalten, die nicht auf 0101 geschaltet werden. Die 
FPGA-Zellen sind in einem 2-dimensionalen Array angeordnet. 0104 stellt eine Kantenzelle dar, die am Rand des Arrays 
50 sitzt und sich somit in nachster Nahe zu den Anschliissen am Rand des Bausteins befindet. 

Fig. 2 zeigt einen weiteren FPGA nach dem Stand der Technik. Diese Ausfuhrungsmoglichkeit arbeitet nicht mit Bus- 
systemen wie 0101 sondern hauptsachlicb mit NextNeighbour-Verbindungen (0201), das sind direkte Verbindungen von 
einer FPGA-Zelle (0203) zu ihrer Nachbarzelle. Es konnen dennoch globale Bussysteme (0202) existieren, diese sind je- 
doch nicht sehr breiL Die FPGA-Zellen oder eine Gruppe von FPGA-Zellen besitzen eine Verbindung zu 0202. Die 
55 FPGA-Zellen sind in einem 2-dimensionalen Array angeordnet. 0204 stellt eine Kantenzelle dar, die am Rand des Arrays 
sitzt und sich somit in nachster Nahe zu den Anschliissen am Rand des Bausteins befindet. 

Fig. 3 zeigt einen DFP nach PACT02. Dabei sind die PAE-Zellen (0303) iiber ein Businterface (0304) auf die Bussy- 
steme (0301) geschaltet. Die Bussysteme 0301 konnen iiber einen Busschalter (0302) miteinander verschaltet werden. 
Die PAE-Zellen sind in einem 2-dimensionalen Array angeordnet. 0305 stellt eine Kantenzelle dar, die am Rand des Ar- 
60 rays sitzt und sich somit in nachster Nahe zu den Anschliissen am Rand des Bausteins befindet. 

Fig. 4a zeigt eine FPGA-Kante nach Fig. 1. AuBerhalb der Kantenzellen (0401) ist eine Mehrzahl von INPUT-/OUT- 
PUT-CELLs (0402) angeordnet, die zu mehreren oder einzeln die internen Bussysteme (0403) mit dem E-BUS (0404) 
verbinden. Dabei ist die Menge der INPUT-/OUTPUT-CELLs von ihrer eigenen Breite im Verhaltnis zur Breite der in- 
ternen Bussysteme abhangig. 0405 stellt ein EB-REG dar. 0406 stellt eine Zustandsmaschine dar. Von der Zustandsma- 
65 schine geht zum EB-REG und jeder einzelnen INPUT-/OUTPUT-CELL ein Bussystem (0407), iiber das die Zustands- 
maschine die INPUT-/OUTPUT-CELLs steuert. Dabei konnen mehrere 0405 und 0406 existieren, indem je eine Menge 
an 0402 zu Gruppen zusammengefaBt werden und von je einer 0405 und 0406 verwaltet werden. 
Fig. 4b zeigt eine FPGA-Kante nach Fig. 2. AuBerhalb der Kantenzellen (0411) ist eine Mehrzahl von INPUT-/OUT- 
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PUT-CELLs (0412) angeordnet, die zu mehreren oder einzeln die internen Bussysteme (0413) und die direkten Verbin- 
dungen der KantenzeUen (0417) mit dem E-BUS (0414) verbinden. Dabei ist die Menge der INPUT-/OXJTPUT-CELLs 
von ihrer eigenen Breite ira Verhaltnis zur Breite der intemen Bussysteme (0413) und der Menge der direkten Verbin- 
dungen (0418) abhangig. 0415 stellt ein EB-REG dar. 0416 stellt eine Zustandsmaschine dar. Von der Zustandsmaschine 
geht zum EB-REG und jeder einzelnen IWUT-/OUTPUT-CELL ein Bussystem (0417), uber das die Zustandsmaschine 5 
die INPUT-/OUTPUT-CELLs steuert. Dabei konnen mehrere 0415 und 0416 existieren, indem je eine Menge an 0412 zu 
Gruppen zusammengefaBt werden und von je einer 0415 und 0416 verwaltet werden. 

Fig. 5 zeigt eine DFP-Kante nach Fig. 3. AuBerhalb der KantenzeUen (0501) ist eine Mehrzahl von INPUT-/OUTPUT- 
CELLs (0502) angeordnet, die zu mehreren oder einzeln die internen Bussysteme (0503) mit dem E-BUS (0504) verbin- 
den. Dabei ist die Menge der IOTUT-/OUTPUT-CELLS von ihrer eigenen Breite im Verhaltnis zur Breite der internen 10 
Bussysteme (0503) abhangig. 0505 stellt ein EB-REG dar. 0506 stellt eine Zustandsmaschine dar. Von der Zustandsma- 
schine geht zum EB-REG und jeder einzelnen IMW-/OUTPUT-CELL ein Bussystem (0507), uber das die Zustands- 
maschine die IKPUT-/OUTPUT-CELLs steuert. Dabei konnen mehrere 0505 und 0506 existieren, indem je eine Menge 
an 0412 zu Gruppen zusammengefaBt werden und von je einer 0505 und 0506 verwaltet werden. 

Fig. 6 zeigt eine OUTPUT-CELL 0601 . AuBerhalb 0601 befindet sich das EB-REG (0602) und die Zustandsmaschine 15 
(0603), sowie ein Tor (0604), das die Zustandsmaschine auf den E-BUS (0605) schaltet, sofem sie E-BUS-MASTER ist. 
Auf das EB-REG kann uber den E-BUS (0605), den I-BUS (0613) und den Ladelogikbus (0609) zugegriffen werden. 
Weiterhin kann bei einem Rucksetzten des Bausteins (Reset) uber einen extemen AnschluB (0614), der aus dem Baustein 
herausgefuhrt ist, das MASTER-Bit gesetzt werden. Die Zustandsmaschine (0603) greift schreibend und lesend auf 0602 
zu. In der OUTPUT-CELL befindet sich ein Multiplexer (0606), der die Steuerung des E-GATE (0607) entweder dem E- 20 
BUS-MASTER oder der Zustandsmaschine (0603) zuordnet. Das MODE-PLUREG (0608) wird uber den Ladelogikbus 
(0609) oder den I-BUS (0613) eingestellt und konflguriert den AdreBzahler (0610), sowie die Zustandsmaschine (z. B. 
ausmaskieren der OUTPUT-CELL). Werden Daten des I-BUS (0613) in das I-GATE-REG (0611) gespeichert, wird der 
Zugriff im SET-REG (0612) vermerkt. Der Zustand von 0612 ist uber 0607 am E-BUS abfragbar. Ein lesender ZugrifT 
(das E-GATE 0607 ist aktiviert) setzt 0612 zuriick. Die von 0610 generierten Adressen und die Daten von 0611 werden 25 
uber das Tor 0607 auf den E-BUS ubertragen. Es besteht die Moglichkeit die OUTPUT-CELL statt uber die Ladelogik 
uber den Baustein (DFP, FPGA, DPGA, o. a.) selbst dynamisch umzukonfigurieren und zu steuern. Hierzu dient der der 
I-BUS-AnschluB an das EB-REG (0602) und das MODE-PLUREG (0608). 

Fig. 7 zeigt eine INPUT-CELL 0701. AuBerhalb 0701 befindet sich das EB-REG (0702) und die Zustandsmaschine 
(0703), sowie ein Tor (MASTER-GATE) (0704), das die Zustandsmaschine auf den E-BUS (0705) schaltet, sofern sie 30 
EBUS-MASTER ist. Auf das EB-REG, kann uber den E-BUS (0705), den I-BUS (0713) und den Ladelogikbus (0709) 
zugegriffen werden. Weiterhin kann bei einem Rucksetzten des Bausteins (Reset) uber einen externen AnschluB (0714), 
der aus dem Baustein herausgefuhrt ist, das MASTER-Bit gesetzt werden. Die Zustandsmaschine (0703) greift schrei- 
bend und lesend auf 0702 zu. In der INPUT-CELL befindet sich ein Multiplexer (0706), der die Steuerung des E-GATE- 
REG (0707) entweder dem E-BUS-MASTER oder der Zustandsmaschine (0703) zuordnet. Das MODE-PLUREG 35 
(0708) wird uber den Ladelogikbus (0709) oder den I-BUS (0713) eingestellt und konfiguriert den AdreBzahler (0710), 
sowie die Zustandsmaschine (z. B. ausmaskieren der INPUT-CELL). Werden Daten des E-BUS (0705) in das E-GATE- 
REG (0707) gespeichert, wird der Zugriff im SET-REG (0712) vermerkt. Der Zustand von 0712 ist uber ein Tor (0715), 
dessen Steuerung die selbe wie beim Latch (0707) ist, am E-BUS abfragbar. Ein lesender ZugrifT, das E-GATE 0711 ist 
aktiviert und die Daten gelangen auf den I-BUS (0713) setzt 0712 uber 0717 zuriick. Aiternativ kann 0712 uber die Zu- 40 
standsmaschine (0703) zuruckgesetzt werden (0718). Die von 0710 generierten Adressen werden uber das Tor (ADR- 
GATE) 0716 auf den E-BUS ubertragen, 0716 wird von der Zustandsmaschine (0703) aktiviert, wenn diese E-BUS-MA- 
STER ist. Es besteht die Moglichkeit die INPUT-CELL statt uber die Ladelogik uber den Baustein (DFP, FPGA, DPGA, 
o. a.) selbst dynamisch umzukonfigurieren und zu steuern. Hierzu dient der der I-BUS-AnschluB an das EB-REG (0702) 
und das MODE-PLUREG (0708). 45 

Fig. 8 zeigt das MODE-PLUREG (0801) einer INPUT- oder OUTPUT-CELL, das uber den Ladelogikbus (0802) von 
der Ladelogik oder iiber einen I-BUS (0808) beschrieben wird. Das jeweilige Bussystem wird iiber den Multiplexer 
(0809) ausgewahlt, dabei ist die Steuerung des Multiplexers nicht eingezeichnet, da eine gewohnliche Dekodierlogik 
verwendet werden kann. Die Zahlereinstellungen, wie Schrittbreite, Zahlrichtung und Freischaltung des Zahlers werden 
direkt (0807) an den Zahler (0803) geleitet. Die Grundadresse kann entweder iiber einen Load (0804) direkt in den Zahler 50 
geschrieben (0805) werden, oder in einem Zusatz (0811) zu 0801 zwischengespeichert werden. Die fur die Zustandsma- 
schine relevanten Eintrage in 0801 gelangen iiber ein Tor (0806), das von der Zustandsmaschine fur die jeweilig akti- 
vierte INPUT- oder OUTPUT-CELL geofmet wird, zur Zustandsmaschine. 

Fig. 9a zeigt eine Businterfaceschaltung mit Zustandsmaschine (0901), MASTER-GATE (0902) und EB-REG (0903). 
Die INPUT-CELLs (0904) transferieren Daten vom E-BUS (0905) auf den E-BUS (0906). Die OUTPUT-CELLs (0907) 55 
transferieren Daten vom IO-BUS (0908) auf den E-BUS (0905). t)ber den Steuerbus (0909) sind samtliche Baugruppen 
miteinander verbunden. 

Fig. 9b zeigt eine Businterfaceschaltung mit Zustandsmaschine (0901), MASTER-GATE (0902) und EB-REG (0903). 
Die INPUT-CELLs (0904) transferieren Daten vom E-BUS (0905) auf den bidirektionalen I-BUS (0910). Die OUTPUT- 
CELLs (0907) transferieren Daten vom bidirektionalen I-BUS (0910) auf den E-BUS (0905). Uber den Steuerbus (0909) 60 
sind samtliche Baugruppen miteinander verbunden. Es sind auch Interfaceschaltungen denkbar, die beide Moglichkeiten 
(Fig. 9a und 9b) gemischt verwenden. 

Fig. 10a zeigt zwei Bausteine (DFPs, FPGAs, DPGAs, o. a.) (1001) iiber den E-BUS (1002) miteinander vernetzt. 

Fig. 10b zeigt die Vernetzung einer Mehrzahl von Bausteinen (DFPs, FPGAs, DPGAs, o. a.) (1001) iiber den E-BUS 
(1002). " 65 

Fig. 10c zeigt die Vernetzung einer Mehrzahl von Bausteinen (DFPs, FPGAs, DPGAs, o. a.) (1001) iiber den E-BUS 
(1002). Die Vernetzung kann zu einer Matrix ausgebaut werden. Ein Baustein (1001) kann auch eine Mehrzahl von Bus- 
systemen (1002) verwalten. 
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Fig. lOd zeigt die Vernetzung eine Bausteins (DFPs, FPGAs, DPGAs, o. a.) (1001) mit einem Speicherbaustein oder 
einer Speicherbank (1003) iiber den E-BUS (1002). 

Fig. lOe zeigt die Vernetzung eine Bausteins (DFPs, FPGAs, DPGAs, o. a.) (1001) mit einem Peripheriebaustein oder 
einer Peripheriegruppe (1004) uber den E-BUS (1002). 
5 Fig. lOf zeigt die Vernetzung eine Bausteins (DFPs, FPGAs, DPGAs, o. a.) (1001) mit einem Speicherbaustein oder 
einer Speicherbank (1003) und mit einem Peripheriebaustein oder einer Peripheriegruppe (1004) iiber den E-BUS 
(1002). 

Fig. lOg zeigt die Vernetzung eine Bausteins (DFPs, FPGAs, DPGAs, o. a.) (1001) mit einem Speicherbaustein oder 
einer Speicherbank (1003) und mit einem Peripheriebaustein oder einer Peripheriegruppe (1004) und einem weiteren 

10 Baustein (DFPs, FPGAs, DPGAs, o. a.) (1001) uber den E-BUS (1002). 

Fig. 11 zeigt den Aufbau des EB-REG. Die Bussysteme E-BUS (1103); Ladelogikbus (1104), uber welchen die Lade- 
logik Zugriff auf das EB-REG hat und der lokale interne Bus zwischen den INPUT-/OUTPUT-CELLs, der Zustandsma- 
schine und dem EB-REG (1105, vgl. 0407, 0417, 0517), sowie moglicherweise ein I-BUS (1114) werden auf einen Mul- 
tiplexer (1106) gefuhrt. Der Multiplexer (1106) wahlt entweder einen der Busse oder die Ruckkopplung auf das Register 

15 (1108) aus und schaltet die Daten zum Eingang des Registers (1108) durch. Das MASTER-Bit wird getrennt iiber den 
Multiplexer (1107) zum Register (1108) gefuhrt. Der Multiplexer wird uber das RESET-Signal (1101) (Riicksetzen oder 
Initialisieren des Bausteines) gesteuert. Liegt ein RESET an, so schaltet der Multiplexer (1107) das Signal eines externen 
Cbipanschlusses (1102) auf den Eingang des Registers (1108) durch, andernfalls wird der Ausgang des Multiplexers 
(1106) auf den Eingang des Registers (1108) durchgeschaltet. Dadurch kann MASTER vorbelegt werden. Das Register 

20 (1108) wird uber den Systemtakt (1112) getaktet. Der Inhalt des Registers (1108) wird uber ein Tor (1109, 1110, 1111, 
1113) auf das jeweils lesend zugreifenden Bussystem (1103, 1104, 1105, 1114) geschaltet. Die Steuerung der Tore (1109, 
1110, 1111, 1113), sowie des Multiplexers (1106) ist nicht eingezeichnet, da eine gewohnliche Dekodierlogik verwendet 
werden kann. 

25 5 Ausfuhrungsbeispiele 

Fig. 12 zeigt ein Beispiel bei dem das Standardbussystems RAMBUS (1203) eingesetzt wird. Ein Baustein (DFPs, 
FPGAs, DPGAs, o. a.) (1201) ist uber das Bussystem (1203) mit weiteren Baugruppen (Speicher, Peripherie, weitere 
DFPs, FPGAs, DPGAs, o. a.) (1202) verbunden. Der Baustein (1201) kann unabhangig vom Bussystem (1203) weitere 
30 AnschluBleitungen (1204), z. B. wie nach dem Stand der Technik iiblich, zum AnschiuB beliebiger Schaltkreise aufwei- 
sen. 

6 Begriffsdefinition 

35 ADR-GATE: Tor, das die Adressen auf den E-BUS aufschaltet, sofern der Baustein E- BUS-MASTER ist. 
DFP: DatenfluBprozessor nach Patent/Offenlegung DE 44 16 881 
DPGA: Dynamisch konfigurierbare FPGAs. Stand der Technik 

D-FlipFlop: Speicherelement, welches ein Signal bei der steigenden Flanke eines Taktes speichert. 
EB-REG: Register, das sie Statussignale zwischen I-BUS und E-BUS speichert. 
40 E-BUS: Externes Bussystem auBerhalb eines Bausteines. 
E-BUS-MASTER: Baustein, der den E-BUS steuert Aktiv. 
E-BUS-SLAVE: Baustein, der vom ErBUS-MASTER angesprochen wird. Passiv. 

E-GATE: Tor, das von der bausteininternen Zustandsmaschine oder vom E-BUS-MASTER: gesteuert wird und Daten 
auf den E-BUS aufschaltet. 

45 E-GATE-REG: Register in das die Daten eingetragen werden, die uber das E-GATE auf den E-BUS Ubertragen werden. 

E-READ: Flag im EB-REG, das anzeigt, daB die OUTPUT-CELLs komplett auf den E-BUS ubertragen wurden. . 

E-WRITE: Flag im EB-REG, das anzeigt, daB der E-BUS komplett in die INPUT-CELLs ubertragen wurde. 

Flag: (Fahne). Statusbit in einem Register, das einen Zustand anzeigt. 

FPGA: Programmierbarer Logikbaustein. Stand der Technik. 
50 Handshake Signalprotokoll, bei dem ein Signal A einen Zustand anzeigt und ein anderes Signal B bestatigt, daB es Signal 

A akzeptiert und darauf reagiert (hat). 

INPUT-CELL: Baugruppe, die Daten vom E-BUS auf einen I-BUS ubertragt. 

I-BUSn: (auch I-BUS) Bausteininternes Bussystem, das auch aus BUndeln von einzelnen Leitungen bestehen kann. n 
gibt die Nummer des Busses an. 
55 II-BUSn: (auch E-BUS) Bausteininternes Bussystem, das auch aus Bundein von einzelnen Leitungen bestehen kann, Der 
Bus wird von einer INPUT-CELL getrieben und geht auf logische Eingange. 
n gibt die Nummer des Busses an. 

IOBUSn: (auch IO-BUS) Bausteininternes Bussystem, das auch aus Bundein von einzelnen Leitungen bestehen kann. 
Der Bus wird von logischen Ausgangen getrieben und geht an eine OUTPUT-CELL, n gibt die Nummer des Busses an. 

60 I-GATE: Tor, das Daten auf den I-BUS aufschaltet. 

I-GATE-REG: Register, das von der bausteininternen Zustandsmaschine oder vom E-BUS-MASTER gesteuert wird und 
in das die Daten eingetragen werden, die uber das I-GATE auf den I-BUS ubertragen werden. 
I-READ: Rag im EB-REG, das anzeigt, daB die INPUT-CELLs komplett auf den I-BUS ubertragen wurden. 
I-WRLTE: Flag im EB-REG, das anzeigt, daB der I-BUS komplett in die OUTPUT-CELLs ubertragen wurde. 

65 Kantenzelle: Zelle am Rand eines Zellarrays, oftmals mit direktem Kontakt zu den Anschlussen eines Bausteines. 

Konfigurieren: Einstellen der Funktion und Vernetzung einer logischen Einheit, einer (FPGA)-Zelle (Logikzelle) oder ei- 
ner PAE (vgl. umkonfigurieren). 

Ladelogik: Einheit zum Konfigurieren und Umkonfigurieren einer PAE oder Logikzelle. Ausgestaltet durch einen spe- 
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ziell an seine Aufgabe angepaBten Mikrokontroller. 

Latch: Speicherelement, das ein Signal fur gewdhnlich wahrend des H-Pegels transparent weiterleitet und wahrend des 
L-Pegels speichert. In PAEs werden teilweise Latches gebraucht, bei denen die Funktion der Pegel genau umgekehrt ist. 
Hierbei wird vor den Takt eines iiblichen Latch ein Inverter geschaltet. 

Logikzellen: Bei DFPs, FPGAs, DPGAs verwendete konfigurierbare Zellen, die einfache logische oder arithmetische 5 
Aufgaben gemaB ihrer Konfiguration erfullen. 

MASTER: Hag im EB-REG, das anzeigt, daB der Baustein EBUS-MASTER ist. 

MODE-PLUREG: Register in dem die Ladelogik die Konfiguration einer IWUT-/OUTPUT-CELL einsteUt. 
OUTPUT-CELL: Baugruppe, die Daten von einem I-BUS auf den E-BUS ubertragt. 

PAE Processing Array Element: EALU mit OREG, R-REG, R20-MUX, F-PLUREG, M-PLUREG, BM-, SM-, Sync-, to 
StateBack- und Power-UNIT. 

PLU: Einheit zum Konfigurieren und Umkonfigurieren einer PAE oder Logikzelle. Ausgestaltet durch einen speziell an 
seine Aufgabe angepaBten Mikrokontroller 

REQ-MASTER: Flag im EB-REG, das anzeigt, daB der Baustein E-BUS-MASTER werden mochte. 

RS-FlipFiop: Reset-/Set-FhpFlop. Speicherelement, das durch 2 Signale umgeschaltet werden kann. is 
SET-REG: Register das anzeigt, daB Daten in ein I-GATE-REG oder E-GATE-REG geschrieben und noch nicht gelesen 
wurden. 

STATE-GATE: Tor, das den Ausgang des SET-REG auf den E-BUS schaltet. 
Ton Schalter, der ein Signal weiterleitet oder sperrt. Einfacher Vergleich: Relais 

Umkonfigurieren: Neues Konfigurieren von einer beliebigen Menge von PAEs oder Logikzellen wahrend eine beliebige 20 
Restmenge von PAEs oder Logikzellen ihre eigenen Funktionen fortsetzen (vgl. konfigurieren). 
Zustandsmaschine: Logik, die diversen Zustanden annehmen kann. Die Ubergange zwischen den Zustanden sind von 
verschiedenen Eingangsparametern abhangig. Diese Maschinen werden zur Steuerung komplexer Funktionen eingesetzt 
und entsprechen dem Stand der Technik 

25 

7 Konventionen 



7.1 Namenskonvention 

Baugruppe -UNIT 30 

Betriebsart -MODE 

Multiplexer -MUX 

Negiertes Signal not- 

Register fur PLU sichtbar -PLUREG 

Register intem -REG 35 
Schieberegisters -sft 

7.2 Funktionskonvention 

Schieberegisters sft 40 
UND-Funktion & 
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B 
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0 


0 


0 


0 


1 


0 


1 


0 


0 


1 


1 


1 
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ODER-Funktion # 

55 



A 


B 


Q 


0 


0 


0 


0 


1 


1 


1 


0 


1 


1 


1 


1 



60 



65 
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NICHT-Funktion ! 



A 


Q 


0 


l 


1 


0 



TOR-Funktion G 



EN 


D 


Q 


0 


0 




0 


1 




1 


0 


0 


1 


1 


1 



Patentanspriiche 

1. Bussystem, hergestellt durch Bundelung mehrere einzelner Leitungen oder Busse oder Teilbusse (vgL Fig. 4/5) 
innerhalb eines Bausteines der Gattung DFP, FPGA, DPGA, sowie alien Bausteinen mit zwei- oder mehrdimensio- 
naler programmierbare Zellslruktur (vgl. Fig. 1/2/3), iiber welches die Bausteine zu mehreren zusammengefaBt 
werden konnen und/oder Speicher und/oder Peripherie anschlieBbar ist (vgl. Fig. 10). 

2. Bussystem nach Anspruch 1, dadurch gekennzeichnet, daB eine oder mehrere Schnittstellen (Fig. 6/7) die Zu- 
sammenfassung der Leitungen ubemehmen und das Bussystem erzeugen. 

3. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daB eine oder mehrere Zustandsmaschine(n) 
(0703/0603) die Schnittstellen (vgl. Fig. 6/7) steuert/steuern. 

4. Bussystem nach Anspruch 1, 2 und 3, dadurch gekennzeichnet, daB die Zustandsmaschine auch den externen 
Bus steuert. 

5. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daB ein AdreBgenerator existiert (0610/0710), der 
die Adressen fur die iiber den Bus zu kontaktierenden Bausteine generiert. 

6. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daB die Schnittstellen ein internes Bussystem oder 
mehrere interne Bussysteme, das/die aus mehreren Leitungen zusammengefaBt sein kann/konnen (vgl. Fig. 4/5), 
zum Schreiben und Lesen verwendet (vgl. Fig. 9a, I-BUS). 

7. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daB die Schnittstellen ein internes Bussystem oder 
mehrere interne Bussysteme, das/die aus mehreren Leitungen zusammengefaBt sein kann/konnen (vgl. Fig. 4/5), 
entweder zum Schreiben oder Lesen verwendet (vgl. Fig. 9b, H-BUS, 10- BUS). 

8. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daB die Schnittstellen ein internes Bussystem oder 
mehrere interne Bussysteme, das/die aus mehreren Leitungen zusammengefaBt sein kann/konnen (vgl. Fig. 4/5), 
nach Anspruch 6 und 7 gemischt betreiben. 

9. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daB ein Register zur \ferwaltung und Steuerung des 
Bussystems existiert (EB-REG, 0702, 0602). 

10. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daB die Bussteuerung durch einen Baustein (E- 
BUS-MASTER) erfolgt, der auf eine Vielzahl von untergeordneten Bausteinen (E-BUS-SLAVE) zugreift. 

11. Bussystem nach Anspruch 1, 2 und 10, dadurch gekennzeichnet, daB die Bussteuerung dynamisch von einem 
Baustein (E-BUS -MASTER) an einen anderen ubergeben wird (MASTER-Eintrag im EB-REG). 

12. Bussystem nach Anspruch 1, 2, 10 und 11, dadurch gekennzeichnet, daB ein untergeordneter Baustein (E-BUS- 
SLAVE) den Erhalt der Buskontrolle fordern kann (REQ-MASTER-Eintrag im EB-REG). 

13. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daB ein Register existiert, das anzeigt, ob Daten in 
den Schnittstellen gespeichert sind (SET-REG, 0612, 0712). 

14. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daB die Schnittstellen entweder direkt auf dem 
Baustein implementiert sind, oder durch die Konfiguration von Logikzellen, das sind Zellen in DFP-, FPGA-, 
DPGA, oder ahnlichen Bausteinen, die einfache logische oder arithmetische Aufgaben gemaB ihrer Konfiguration 
erfullen, entstehen. 

15. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daB die Schnittstellen von einer Ladelogik und/ 
oder dem Baustein selbst (vgl. Fig. 8/11) konfiguriert werden konnen. 

16. Bussystem nach Anspruch 1, 2 und 15, dadurch gekennzeichnet, daB die Ladelogik partiell auf dem Baustein 
integriert ist. 

17. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daB Standardbussysteme eingesetzt werden kon- 
nen (vgl. Fig. 12). 

18. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daB der Baustein weitere gewohnliche Anschliisse 
nach bei DFPs, FPGAs, DPGAs, o. a. ublicher Art besitzt (vgl. Fig. 12 1201, 1204). 



Hierzu 1 1 Seite(n) Zeichnungen 



10 



ZEICHNUNGEN SEITE 1 



Numrner: 
Int. CI. 6 : 

Offenlegungstag: 



DE 196 54 595 A 1 
G06F 13/40 

2. Juli 1998 




802 027/173 



ZEICHNUNGEN SEITE 2 



Nummer: 
Int. CI. 6 : 

Offenlegungstag: 



DE19654595A1 
G 06 F 13/40 

2. Juli 1998 




802 027/173 



ZEICHNUNGEN SEITE 3 



Nummen 
Int. CI. 6 : 

Offenlegungstag: 



DE196 54 595A1 
G08F 13/40 

2. Jul! 1998 




802 027/173 



ZEICHNUNGEN SEITE4 



Nummer; 
Int. CI. 6 : 

Offenlegungstag: 



DE 19654 595 A1 
G06F 13/40 

2. Juli 1998 



CD 




tO 

4- 



oo 



cd 



Jl 



itn 



3Q 



ii 



rt "It 



~Ti~i-r- 



OOP 



CD 



CD 



vo 

id 



O 
CD 



O 



CD 
CD 



EX3 



CdD 



CD 



■ ■ 


J 


- -1 - 
cv 


_ i— . 


l.-„ 


i 


i 


i 




. 1. ... 






CD 














o 


























CdD 














CD 



er r nr 



4- 



e 

■=r 



802 027/173 



ZEICHNUNGEN SEITE 5 



Nummer. 
Int. CI. 6 : 

Offenlegungstag: 



DE 19654 595 A1 
G 06 F 13/40 

2. Jul! 1998 



0605 



0606/- 



0607 g 



1 060] 



0609 



*| 0604 




0603 





06M ^ 



0610 



0608 



« SET ^» 

s o 



0612 



06^ 



0602 



'0615 



mis 



*>06t3 



802 027/173 



ZEICHNUNGEN SEITE 6 



Nummer: 
Int. CI. 6 : 

Offenlegungstag: 



DE19654 595A1 
G 06 F 13/40 

2. Juli 1998 



0705 



*>07i;) 




0713 



»07J3 



802 027/173 



ZEICHNUNGEN SEITE7 



Nummer. 
Int. CI. 6 : 

Offenlegungstag: 



DE13654 595A1 
G06F 13/40 

2. Jult 1998 



o 

3 E 




802 027/173 



ZEICHNUNGEN SEITE8 



Nummer: 
Int. CI. 6 : 

Offenlegungstag: 



DE196 54 595A1 
G06F 13/40 

2. Juli 1998 




CP 

o 
cr 
CD 






r— 






r- 


CD 


cd 




cd 


o 


cr 


cr 




cr 


cr 


O 


CD 




CD 


CD 



cr 



cr 




CD 

cr 

CD 




oo 
CD 
cr 
CD 



CD 

cr 
CD 



CO 
CD 

cr 



cr 

CD 
CD 













CD 


CD 




CD 


CD 


cr 


Cr 




cr 


cr 


CD 


CD 




CD 


CD 



35£ 



a 
cr 



o 
cr 

C2> 



802 027/173 



ZEICHNUNGEN SEITE9 



Nummen 
Int. CI. 6 : 

Offenlegungstag: 



DE19654595A1 
G06F 13/40 

2. Juli 1998 




802 027/173 



ZEICHNUNGEN SEITE 10 



Nummer: 
Int. CI. 6 : 

Offenlegungstag: 



DE196 54 595A1 
G06F 13/40 

2. Juli 1998 



CD 



rO 




cr 




O 










O 
























"V 


5 — 










x — 




I — 


"5 — 



oo 
O 



lqh\ 



90 n 



802 027/173 



ZEICHNUNGEN SEITE 11 Nummen DE 196 54 595 A1 

Int. CI. 6 : G 08 F 13/40 

Offenlegungstag: 2. Jul! 1998 




802 027/173 



